System.Array.Sort 方法 (T[], Int32, Int32, IComparer)

方法描述

使用指定的 IComparer 泛型接口,对 Array 中某个元素范围内的元素进行排序。

语法定义(C# System.Array.Sort 方法 (T[], Int32, Int32, IComparer) 的用法)

public static void Sort(
	T[] array,
	int index,
	int length,
	IComparer comparer
)

参数/返回值

参数值/返回值 参数类型/返回类型 参数描述/返回描述
array T[] 要排序的从零开始的一维 Array。
index System-Int32 排序范围的起始索引。
length System-Int32 排序范围内的元素数。
comparer System-Collections-Generic-IComparer 比较元素时使用的 IComparer 泛型接口实现;如果为 null,则使用每个元素的 IComparable 泛型接口实现。
返回值 void

提示和注释

如果 comparer 为 null,则 array 的指定部分元素中的每个元素均必须实现 IComparable 泛型接口,才能与 array 中的其他所有元素进行比较。

如果排序不能成功地完成,则结果未定义。

此方法使用 QuickSort 算法。 此实现执行不稳定排序;亦即,如果两元素相等,则其顺序可能不被保留。 相反,稳定排序则会保持相等元素的顺序。

一般情况下,此方法的运算复杂度为 O(n log n),其中 n 是 length;最坏的情况下其运算复杂度为 O(n ^ 2)。

System.Array.Sort 方法 (T[], Int32, Int32, IComparer)例子

如果您使用 Ildasm.exe(MSIL 反汇编程序) 检查 Microsoft 中间语言 (MSIL),则可以看到正在调用泛型方法。

using System;
using System.Collections.Generic;

public class ReverseComparer: IComparer
{
    public int Compare(string x, string y)
    {
        // Compare y and x in reverse order.
        return y.CompareTo(x);
    }
}

public class Example
{
    public static void Main()
    {
        string[] dinosaurs = {"Pachycephalosaurus", 
                              "Amargasaurus", 
                              "Mamenchisaurus", 
                              "Tarbosaurus",
                              "Tyrannosaurus", 
                              "Albertasaurus"};

        Console.WriteLine();
        foreach( string dinosaur in dinosaurs )
        {
            Console.WriteLine(dinosaur);
        }

        Console.WriteLine("\nSort(dinosaurs, 3, 3)");
        Array.Sort(dinosaurs, 3, 3);

        Console.WriteLine();
        foreach( string dinosaur in dinosaurs )
        {
            Console.WriteLine(dinosaur);
        }

        ReverseComparer rc = new ReverseComparer();

        Console.WriteLine("\nSort(dinosaurs, 3, 3, rc)");
        Array.Sort(dinosaurs, 3, 3, rc);

        Console.WriteLine();
        foreach( string dinosaur in dinosaurs )
        {
            Console.WriteLine(dinosaur);
        }
    }
}

/* This code example produces the following output:

Pachycephalosaurus
Amargasaurus
Mamenchisaurus
Tarbosaurus
Tyrannosaurus
Albertasaurus

Sort(dinosaurs, 3, 3)

Pachycephalosaurus
Amargasaurus
Mamenchisaurus
Albertasaurus
Tarbosaurus
Tyrannosaurus

Sort(dinosaurs, 3, 3, rc)

Pachycephalosaurus
Amargasaurus
Mamenchisaurus
Tyrannosaurus
Tarbosaurus
Albertasaurus
 */

异常

异常 异常描述
ArgumentNullException array 为 null。
ArgumentOutOfRangeException
  • index 小于 array 的下限。
  • length 小于零。
ArgumentException
  • index 和 length 不指定 array 中的有效范围。
  • comparer 的实现导致排序时出现错误。 例如,将某个项与其自身进行比较时,comparer 可能不返回 0。
InvalidOperationException comparer 为 null,并且 array 中的一个或多个元素未实现 IComparable 泛型接口。

命名空间

namespace: System

程序集: mscorlib(在 mscorlib.dll 中)

版本信息

.NET Framework 受以下版本支持:4、3.5、3.0、2.0 .NET Framework Client Profile 受以下版本支持:4、3.5 SP1 受以下版本支持:

适用平台

Windows 7, Windows Vista SP1 或更高版本, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008(不支持服务器核心), Windows Server 2008 R2(支持 SP1 或更高版本的服务器核心), Windows Server 2003 SP2 .NET Framework 并不是对每个平台的所有版本都提供支持。有关支持的版本的列表,请参见.NET Framework 系统要求。